package cn.zy.basic.util;

import cn.zy.basic.jwt.JwtUtils;
import cn.zy.basic.jwt.LoginData;
import cn.zy.basic.jwt.Payload;
import cn.zy.basic.jwt.RsaUtils;
import cn.zy.user.domain.Logininfo;
import javax.servlet.http.HttpServletRequest;
import java.security.PublicKey;

/**
 * 工具类:获取当前登录人的信息
 * 在系统中,审核店铺,宠物上下架,服务审核都需要审核人 - 当前登录人
 */
public class LoginContext {

    public static Logininfo getLogininfo(HttpServletRequest request){
        //1.获取请求头中的token
        String token = request.getHeader("token");
        if(token != null){
            try {
                //2.获取公钥
                PublicKey publicKey = RsaUtils.getPublicKey(JwtUtils.class.getClassLoader()
                        .getResource("auth_rsa.pub").getFile());
                //3.使用工具类解密获取载荷PayLoad
                Payload<LoginData> payload = JwtUtils.getInfoFromToken(token, publicKey, LoginData.class);
                //如果没有报错 => 登录了
                return payload.getLoginData().getLogininfo();//返回登录信息
            } catch (Exception e) {
                return null;
            }
        }
        return null;
    }
}
